// 上面这个代码处理过度动画（默认加上不用管）
document.addEventListener('DOMContentLoaded', () => {
  setTimeout(() => {
    document.body.classList.add('sidenav-pinned')
    document.body.classList.add('ready')
  }, 200)
})

// 每个页面都会导入该js 统一的设置写这里即可
//基地址
axios.defaults.baseURL = 'http://ajax-api.itheima.net'
//表示停留2秒消失
const myToast = new bootstrap.Toast(document.querySelector('#myToast'), {
  delay: 2000,
})

function tip(msg) {

  // 将传入的msg设置为弹框的内容
  document.querySelector('#myToast .toast-body').innerHTML = msg
  // 调用 显示
  myToast.show()
}
// 该名字
const ncxm = localStorage.getItem('username')
const xm = document.querySelector('#navbar-main .font-weight-bold')
if (ncxm) {
    xm.innerHTML=ncxm
}

// 退出
document.querySelector('#logout').olick = () => {
  localStorage.removeItem('username')
  localStorage.removeItem('token')
  location.assign('./index copy.html')

}



//拦截头
// 添加请求拦截器
axios.interceptors.request.use(function (config) {
  // 在发送请求之前做些什么
  config.headers.Authorization=localStorage.getItem('token')
  return config;
}, function (error) {
  // 对请求错误做些什么
  return Promise.reject(error);
});

// 相应解构

// 添加响应拦截器
axios.interceptors.response.use(function (response) {
  // 2xx 范围内的状态码都会触发该函数。
  // 对响应数据做点什么
  console.dir(response);
  return response.data;
}, function (error) {
  // 超出 2xx 范围的状态码都会触发该函数。
  // 对响应错误做点什么
  return Promise.reject(error);
});



